package cn.edu.xjtu.carlWay.dpRepractice.bestTimeToBuyAndSellStockII;

/**
 * @author Hydrion-QLz
 * @date 2022-05-03 10:34
 * @description https://leetcode-cn.com/problems/best-time-to-buy-and-sell-stock-ii/
 * <p>
 * 122. 买卖股票的最佳时机 II
 * 给你一个整数数组 prices ，其中 prices[i] 表示某支股票第 i 天的价格。
 * <p>
 * 在每一天，你可以决定是否购买和/或出售股票。你在任何时候 最多 只能持有 一股 股票。你也可以先购买，然后在 同一天 出售。
 * <p>
 * 返回 你能获得的 最大 利润 。
 */
class Solution {
    public int maxProfit(int[] prices) {
        if (prices.length == 1) {
            return 0;
        }
        int notHave = 0;
        int have = -prices[0];
        for (int i = 1; i < prices.length; i++) {
            notHave = Math.max(notHave, have + prices[i]);
            have = Math.max(have, notHave - prices[i]);
        }
        return Math.max(notHave, have);
    }
}
